﻿using System;
using System.Collections.Generic;
using System.Linq;
using System.ComponentModel;
using System.Text;
using Csla;
using lite;
using Csla.Validation;
using Csla.Data;
using System.Data.SqlClient;
using ZX.DAL;
using OpenExpressApp.ORM;

namespace ZX.SYS.Library
{
    /// <summary>
    /// 蔡龙丰 2014-09-18 11:27:09
    /// 推送情况视图
    /// </summary>
    [Serializable]
    [Table(Name = "V_DatSysNewsPush")]
    [ZX.DBModule.Table("V_DatSysNewsPush", "ID")]
    public class V_DatSysNewsPush : ZX.DBModule.BaseEntity
    {
        #region Business Methods 业务方法
        /// <summary>
        /// 编号
        /// </summary>
        private static PropertyInfo<Guid> IDProperty = RegisterProperty(typeof(V_DatSysNewsPush), new PropertyInfo<Guid>("ID"));
        [DataObjectField(true, true)]
        [Column, PK]
        public Guid ID
        {
            get { return GetProperty(IDProperty); }
            set { SetProperty(IDProperty, value); }
        }

        /// <summary>
        /// 设备号
        /// </summary>
        private static PropertyInfo<string> mobileIDProperty = RegisterProperty(typeof(V_DatSysNewsPush), new PropertyInfo<string>("mobileID"));
        [Column]
        public string mobileID
        {
            get { return GetProperty(mobileIDProperty); }
            set { SetProperty(mobileIDProperty, value); }
        }
        /// <summary>
        /// 标题
        /// </summary>
        private static PropertyInfo<string> TitleProperty = RegisterProperty(typeof(V_DatSysNewsPush), new PropertyInfo<string>("Title"));
        [Column]
        public string Title
        {
            get { return GetProperty(TitleProperty); }
            set { SetProperty(TitleProperty, value); }
        }
        /// <summary>
        /// 创建时间
        /// </summary>
        private static PropertyInfo<DateTime> CreatedOnProperty = RegisterProperty(typeof(V_DatSysNewsPush), new PropertyInfo<DateTime>("CreatedOn"));
        [Column]
        public DateTime CreatedOn
        {
            get { return GetProperty(CreatedOnProperty); }
            set { SetProperty(CreatedOnProperty, value); }
        }
        /// <summary>
        /// 修改时间
        /// </summary>
        private static PropertyInfo<DateTime> ModifiedOnProperty = RegisterProperty(typeof(V_DatSysNewsPush), new PropertyInfo<DateTime>("ModifiedOn"));
        [Column]
        public DateTime ModifiedOn
        {
            get { return GetProperty(ModifiedOnProperty); }
            set { SetProperty(ModifiedOnProperty, value); }
        }
        /// <summary>
        /// 预计发送时间
        /// </summary>
        private static PropertyInfo<DateTime> PlanTimeProperty = RegisterProperty(typeof(V_DatSysNewsPush), new PropertyInfo<DateTime>("PlanTime"));
        [Column]
        public DateTime PlanTime
        {
            get { return GetProperty(PlanTimeProperty); }
            set { SetProperty(PlanTimeProperty, value); }
        }
        /// <summary>
        /// 实际发送时间
        /// </summary>
        private static PropertyInfo<DateTime> SendTimeProperty = RegisterProperty(typeof(V_DatSysNewsPush), new PropertyInfo<DateTime>("SendTime"));
        [Column]
        public DateTime SendTime
        {
            get { return GetProperty(SendTimeProperty); }
            set { SetProperty(SendTimeProperty, value); }
        }
        /// <summary>
        /// 总过还有多少未阅读
        /// </summary>
        private static PropertyInfo<int> TotalNumProperty = RegisterProperty(typeof(V_DatSysNewsPush), new PropertyInfo<int>("TotalNum"));
        [Column]
        public int TotalNum
        {
            get { return GetProperty(TotalNumProperty); }
            set { SetProperty(TotalNumProperty, value); }
        }
        /// <summary>
        /// 发送结果
        /// </summary>
        private static PropertyInfo<string> IsFinProperty = RegisterProperty(typeof(V_DatSysNewsPush), new PropertyInfo<string>("IsFin"));
        [Column]
        public string IsFin
        {
            get { return GetProperty(IsFinProperty); }
            set { SetProperty(IsFinProperty, value); }
        }
        /// <summary>
        /// 返回值状态[0-否，1-是]
        /// </summary>
        private static PropertyInfo<string> IsResultOKProperty = RegisterProperty(typeof(V_DatSysNewsPush), new PropertyInfo<string>("IsResultOK"));
        [Column]
        public string IsResultOK
        {
            get { return GetProperty(IsResultOKProperty); }
            set { SetProperty(IsResultOKProperty, value); }
        }
        /// <summary>
        /// 错误消息
        /// </summary>
        private static PropertyInfo<string> ErrMsgProperty = RegisterProperty(typeof(V_DatSysNewsPush), new PropertyInfo<string>("ErrMsg"));
        [Column]
        public string ErrMsg
        {
            get { return GetProperty(ErrMsgProperty); }
            set { SetProperty(ErrMsgProperty, value); }
        }

        #endregion

        #region Validation Rules 验证规则
        //将验证规则与业务对象的属性联系在一起
        protected override void AddBusinessRules()
        {
            //AddRule的第一个参数是委托变量，也就是说是方法的变量
            base.AddBusinessRules();
        }
        #endregion

        #region Factory Methods 工厂方法

        public V_DatSysNewsPush() { }

        public static V_DatSysNewsPush New()
        {
            return DataPortal.Create<V_DatSysNewsPush>();
        }
        public static V_DatSysNewsPush Get(Guid ID)
        {
            return DataPortal.Fetch<V_DatSysNewsPush>(new SingleLazyCriteria<V_DatSysNewsPush, Guid>(ID, false));
        }
        public static void Delete(Guid ID)
        {
            DataPortal.Delete(ID);
        }

        #endregion

        #region Data Access 数据访问
        //由于DataPortal_create中没有对数据库的访问，所有标记了Runlocal特性，使得该方法只需在本地运行即可
        //如果代码中有访问数据库的方法，那么就不要用这个特性，使数据门户可以根据情况将此方法的运行选择在应用服务器还是本地
        [RunLocal()]
        protected override void DataPortal_Create()
        {
            //在此调用CheckRules对所有的属性进行验证规则的检查，这样检查只运行一次。
            ValidationRules.CheckRules();
        }


        //可以看到此方法没有标记任何特性
        //此方法要访问数据库所以不能标记本地，由于她没有任何数据库更新操作所以也无需事务性的保护
        //此方法调用结束后会隐含的调用MarkOld（）方法
        private void DataPortal_Fetch(Guid ID)
        {
            //通过连接字符串建立SQL连接对象，Using符号代表，范围释放的意思，SqlConnection对象会在此范围后被释放掉
            using (var ctx = ConnectionManager<SqlConnection>.GetManager(ConnectionStringNames))
            {
                IDb db = DbFactory.Instance.GetDb(ctx.Connection);
                IQuery q = db.Query();
                q.Constrain("ID").Equal(ID);

                var data = db.Select<V_DatSysNewsPush>(q)[0];
                LoadProperty(IDProperty, data.ID);
                LoadProperty(mobileIDProperty, data.mobileID);
                LoadProperty(TitleProperty, data.Title);
                LoadProperty(CreatedOnProperty, data.CreatedOn);
                LoadProperty(ModifiedOnProperty, data.ModifiedOn);
                LoadProperty(PlanTimeProperty, data.PlanTime);
                LoadProperty(SendTimeProperty, data.SendTime);
                LoadProperty(TotalNumProperty, data.TotalNum);
                LoadProperty(IsFinProperty, data.IsFin);
                LoadProperty(IsResultOKProperty, data.IsResultOK);
                LoadProperty(ErrMsgProperty, data.ErrMsg);
            }
        }

        [Transactional(TransactionalTypes.TransactionScope)]
        protected override void DataPortal_DeleteSelf()
        {
            //依然是调用下面的方法删除的，只是他此时可以获得自己的Id
            DataPortal_Delete(IDProperty);
        }
        #endregion
    }
}

